html,
body {
	--bs-color-rgb: 245, 70, 71;
	--bs-color-opacity: 1;
	--bs-color: rgba(var(--bs-color-rgb), var(--bs-color-opacity)) !important;
	--bs-body-font-weight: 300;
	--bs-secondary-rgb: 140, 140, 140;

	--bs-btn-color-bg: rgba(165, 51, 234, 1);
	--bs-btn-active-color: #ffffff;
	--bs-btn-active-bg: rgba(var(--bs-color-rgb), 0.8);
	--bs-btn-hover-color: #ffffff;
	--bs-btn-hover-bg: rgba(var(--bs-color-rgb), 0.8);

	--bs-link-color: whtie;
	--bs-light-rgb: 250, 250, 250;

	--bs-link-hover-color: var(--bs-color);

	overflow: hidden;
	overflow-y: auto;
	--bs-navbar-brand-color: #ffffff;

	/* font-family: "Noto Sans","Noto Sans SC","MHei","微軟正黑體","Microsoft JhengHei",sans-serif; */
	background: #1B1B29;
}

:focus-visible {
	outline: -webkit-focus-ring-color auto 0px;
}
a{
	text-decoration: initial;
	-webkit-transition: all 0.2s ease;
	transition: all 0.2s ease;
}
:focus {
	outline: -webkit-focus-ring-color auto 0px;
}

.big-title {
	font-size: 3.75rem;
	line-height: 1.5;
}

.big-title-md {
	font-size: 2.625rem;
}

.big-desc {
	font-size: 1.125rem;
	line-height: 1.5;
	color: #595959;
	margin: 1.5rem 0;
	font-weight: 300;
}
hr{ opacity: 1;}
.btn {
	background: var(--bs-btn-color-bg);
	color: #ffffff;
	border-radius: 999px;
	background-image: linear-gradient(101deg, #F8A2ED 0%, #934EAE 100%);
	border: 0;
	transition: 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}

.big-btn {
	width: 13.125rem;
	height: 3.75rem;
	/*background: #E74746;*/
	text-decoration: initial;
}
.big-btn-outline-primary{
	width: 13.125rem;
	height: 3.75rem;
	background: #D7DFEC;
	color: #191928;
}

.text-truncate{
	overflow: hidden;
	-webkit-line-clamp: 1;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-box-orient: vertical;
}
.text-truncate-2 {
	overflow: hidden;
	-webkit-line-clamp: 2;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-box-orient: vertical;
}
.text-truncate-3 {
	overflow: hidden;
	-webkit-line-clamp: 3;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-box-orient: vertical;
}
.text-truncate-5 {
	overflow: hidden;
	-webkit-line-clamp: 3;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-box-orient: vertical;
}
.clearfix{clear: both}
header{
	--bs-navbar-height: 56px;
	transition: all 0.5s;
	background: rgba(34, 34, 40, 0.5);
}
.navbar {
	 --bs-navbar-padding-y: 0;
	--bs-navbar-padding-x: 0;
	--bs-navbar-brand-color: #ffffff;
	--bs-navbar-brand-hover-color: #ffffff;
	height: var(--bs-navbar-height);
}
.navbar-collapse{
	/*height: var(--bs-navbar-height);*/
}

.tag {
	color: var(--bs-color);
}

.header-logo {
	width: 9.375rem  /* 150/16 */;
	height: 2.1875rem  /* 35/16 */;
}
/*.fixed-top {*/
/*	background: rgba(34, 34, 40, 0.5);*/
/*}*/
/*.fixed-top.header-scrolled {*/
/*	background: #13131d;*/
/*}*/
.fixed-top{
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
	width: 100%;
	box-shadow: 0 8px 20px 0 rgba(0,0,0,.1);
	-webkit-animation: headerSlideDown .95s ease forwards;
	animation: headerSlideDown .95s ease forwards;
	will-change: transform;
	background: rgba(19, 19, 29, 0.7);
	backdrop-filter: blur(15px);
}
@keyframes headerSlideDown {
	0% {
		-webkit-transform: translateY(-100%);
		transform: translateY(-100%)
	}

	to {
		-webkit-transform: translateY(0);
		transform: translateY(0)
	}
}

.navbar-nav {
	--bs-navbar-color: #ffffff;
	 --bs-navbar-nav-link-padding-x: 0.75rem;
	--bs-nav-link-hover-color: #ffffff;
}

.navbar-nav .nav-link {
	/* font-size: 0.875rem; */
}

.navbar-nav>.active>.nav-link {
	color: var(--bs-color);
	font-weight: bold;
}

.navbar-nav>li {
	position: relative;
}

.navbar-nav>li:after {
	content: "";
	background: var(--bs-color);
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 3px;
	width: 0;
	transition: .5s;
	border-radius: 3px;
	margin: auto;
}

.navbar-nav>.active:after {
	width: 30px;
	left: 0;
	right: 0;
}
.navbar-brand{
	float: left;
	height: var(--bs-navbar-height);
}
.contact-button{
	height: var(--bs-navbar-height);
	display: flex;
}
.banner-home {
	position: relative;
	height: calc(100vh - 100px)
}

.banner-home::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 0;
	background: url(../../assets/img/banner-home.png);
	background-position: right bottom;
	background-size: contain;
	background-repeat: no-repeat;
	display: block;
	width: 35%;
	height: 100%;
}
.header-wechat{
	position: relative;
}
.header-wechat .top-qrcode {
	display: block;
	border: 1px solid rgba(179,179,179,.3);
	position: absolute;
	border-radius: 0.714rem;
	background: #fff;
	transition: .5s;
	opacity: 0;
	width: 12rem;
	max-width: 200px;
	left: 50%;
	margin-left: -6rem;
	bottom: calc(-12rem - 10px);
	z-index: 1;
	padding: 1rem;
	transform: scale(0);
}
.header-wechat .top-qrcode .after {
	display: block;
	content: "";
	background-color: #fff;
	width: 10px;
	height: 10px;
	position: absolute;
	top: 0;
	left: 50%;
	margin-left: -5px;
	box-shadow: 3px 3px 7px #00000012;
	pointer-events: auto;
	transform: translateY(-6.24264069px) rotate(45deg);
	z-index: 0;
}
.header-wechat:hover .top-qrcode {
	display: block;
	opacity: 1;
	transform: scale(1);
	box-shadow: 0 3px 6px -4px #0000001f, 0 6px 16px #00000014, 0 9px 28px 8px #0000000d;
}
.section-home {
	height: 100vh;
}
.section-home>*{
	z-index: 1;
}

.section-home>.banner-bg{
	width: 50%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	/* background: rgb(0 0 0 / 45%); */
	z-index: 0;
	background-image: linear-gradient(90deg, #000000 0%, #00000000 100%);
}
.section-service p{
	opacity: 0.5;
}
.section-partner .item{
	background: #12121E;
	border-radius: 20px;
	margin-top: 1.5rem  /* 24/16 */;
	/*padding: 4.375rem 0 !* 70/16 *!;*/
	/*height: 13.5rem  !* 216/16 *!;*/
	padding-bottom: 56.25%;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.section-partner .item img{
	max-width: 80%;
	max-height: 7.5rem  /* 120/16 */;
	object-fit: contain;
	position: absolute;
	right: 0;
	top: 50%;
	bottom: 0;
	left: 50%;
	transform:translate(-50%,-50%)
}
.section-news{

}
.section-news .text-wrap{
	display: block;
	padding-bottom: 1.075rem  /* 30/16 */;
	white-space: nowrap;
	text-overflow: ellipsis;
	text-align: left;
}
.section-news .text-wrap .title{
	margin-bottom: 15px;
	font-size: 1.25rem  /* 24/16 */;
}
.section-news .text-wrap .title-xs{
	margin-bottom: 15px;
	font-size: 1.25rem  /* 18/16 */;
}
.section-news .text-wrap .des{
	font-size: 1rem  /* 16/16 */;
	color: #666;
	overflow: hidden;
	color: rgba(255,255,255,0.5);
}

.device-bezels {
	text-align: center;
	position: relative;
	width: 19.3125rem;
	height: 38.9375rem;
	padding: 15px 15px;
	box-sizing: border-box;
	margin: auto;
}

.device-bezels::after {
	content: "";
	display: block;
	background: url(../../assets/img/iPhone14_Starlight.svg);
	background-repeat: no-repeat;
	background-size: 99%;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	right: 0;
	position: absolute;
}
.what-item > .portfolio-img{
	position: relative;
	overflow: hidden;
	padding: 1rem 0;
}
.what-item > .portfolio-img img{
	max-width: 40%;
	height: 11.25rem;
	object-fit: contain;
}
.what-item > .portfolio-img:before {
    background: rgba(34, 34, 40);
    content: "";
    opacity: 0;
    position: absolute;
    transition: all 0.4s ease-in-out 0s;
}
.what-item .portfolio-desc {
    left: 0;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    opacity: 0;
    transition: all 0.3s ease-in-out 0s;
	bottom: 0;
	padding: 0 30px;
	top: inherit;
}

.portfolio-desc span {
	font-size: 1rem;
    color: #ffffff;
    display: inline-block;
    font-weight: normal;
    transform: translateY(10px);
    transition: all 0.4s ease-in-out 0s;
    text-transform: capitalize; 
}

.what-item:hover .portfolio-desc {
    opacity: 1;
}
.what-item:hover .portfolio-desc span {
    transform: translateY(-50%);
}
.portfolio-img::before {
    background: #000 none repeat scroll 0 0;
    bottom: 0;
    left: 0;
    opacity: 0;
    right: 0;
    top: 0;
}

.what-item:hover .portfolio-img:before {
    opacity: 0.76;
}
.case-item-tag {
	display: inline-block;
	background: var(--bs-btn-color-bg);
	color: white;
	border-radius: 999px;
	padding: 0.1875rem 0.9375rem;
	font-size: 0.875rem;
}
.case-swiper{
	padding-bottom: 20px;
	--swiper-pagination-color: #222228;
	--swiper-pagination-bullet-inactive-opacity: 1;
}
.swiper-horizontal> .case-swiper-pagination{
	bottom: 0;
}
.case-swiper .swiper-pagination-bullet{
	border: 2px solid #BFBFBF;
	background: #ffffff;
}
.case-swiper .swiper-pagination-bullet-active{
	border: 2px solid var(--swiper-pagination-color);
	background: var(--swiper-pagination-color);
}
.news-first .item {
	padding: 3.75rem;
}

.form-label {
	font-weight: 400;
}

.form-control:focus {
	box-shadow: 0 0 0 0 rgba(0, 123, 255, .25);
	border-color: rgba(var(--bs-color-rgb), 0.5);
}
.nav-tabs{
	border: 0;
}
.nav-tabs>li>a{
	font-size: 1.2rem  /* 24/16 */;
	color: #FFFFFF;
	display: inline-block;
	position: relative;
	padding-bottom: 1rem;
}

.nav-tabs>li{
	padding: 10px 24px 0 0;
}
.nav-tabs>li>a:after{
	content: "";
	position: absolute;
	height: 4px;
	background-image: linear-gradient(177deg, #F8A2ED 0%, #934EAE 100%);
	border-radius: 2px;
	display: block;
	margin: 5px auto;
	width: 0;
	left: auto;
	right: 0;
	bottom: 0;
	-webkit-transition: width .6s cubic-bezier(.25,.8,.25,1) 0s;
	transition: width .6s cubic-bezier(.25,.8,.25,1) 0s;
}
.nav-tabs>li.active a:after,
.nav-tabs>li:hover a:after{
	width: 100%;
	right: auto;
}

.section-case .tab-content>.tab-pane{
	display: none;
}
.section-case .tab-content>.tab-pane.active{
	opacity: 1;
	display: block;
}
.section-case .item-case{
	background: #222231;
	border: 1px solid #ffffff1a;
	border-radius: 20px;
	overflow: hidden;
	margin-bottom: 1rem;
	height: 100%;
}
.section-case .item-case .item-img-wrap{
	width: 250px;
	display: block;
}
.section-case .item-case .item-img{
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	object-fit: cover;
}
footer{
	background: rgb(0 0 0 / 30%);
}

.register .form-domain {
	border: 0;
	background: #EFF0F4;
	font-size: 0.875rem;
	padding: 0;
	display: inline-block;
	width: auto;
	border-radius: 0;
}

.contact a {
	color: white;
	text-decoration: none;
}

.contact ul {
	list-style-type: none;
	padding-left: 0;
	padding: 5rem;
	border: 2px solid rgb(255 255 255 / 30%);
	border-radius: 10px;
}

.contact ul li .item-laber {
	font-size: 0.75rem;
	color: #A8ACB9;
	margin-bottom: 1rem;
}

.contact ul li .item-desc {
	font-size: 1.125rem;
}

.contact ul li {
	align-items: center;
	margin-bottom: 1.75rem;
}
/*--------------------------------------------------------------
# Breadcrumbs
--------------------------------------------------------------*/
.breadcrumbs {padding:0.9375rem 0;min-height:2.5rem;color:#ffffff;margin-bottom: 2.5rem;}
.breadcrumbs a {color:#ffffff;}
.breadcrumbs ol li + li::before {
	color: #CCCCCC;
	content: "/ ";
	padding: 0 5px;
}
.breadcrumbs h2 {font-size:1.75rem;font-weight:300;}
.breadcrumbs ol {display:flex;flex-wrap:wrap;list-style:none;padding:0;margin:0;}
.breadcrumbs ol li + li {padding-left:0.625rem;}
/*.breadcrumbs ol li + li::before {display:inline-block;padding-right:0.625rem;color: #999999;content:">";}*/

.contact .form .form-control {
	background: rgb(239 240 244 / 10%);
	border-radius: 999px;
	border: 1px solid rgb(239 240 244 / 10%);
	font-size: 0.875rem;
	padding: 0.75rem 1rem;
	color: white;
}

.contact .form textarea.form-control {
	height: 7.5rem;
	border-radius: 10px;
}
.contact .form-group.has-error .form-control{
	border-color: var(--bs-color);
}
.contact .form .form-select {
	background-image: url(../../assets/img/arrow-Icon.png);
	background-position: 90% center;
	background-repeat: no-repeat;
	background-size: 0.75rem  /* 12/16 */;
}
#select-province,
#select-city {
	color: #868e96;
}

.contact .form-group.has-error .help-block{
	color: var(--bs-color);
	display: none !important;
}

.footer-logo{
	width: 16.25rem  /* 260/16 */;
}
.copyright {
	font-size: 0.875rem;
}
footer .footer-info ul {
	list-style: none;
	margin: 0;
	padding: 0;
	line-height: 1.5;
}
footer .footer-info .link #menu-footer-menu li {
	display: inline-block;
}

footer .footer-info .link #menu-footer-menu li:after {
	content: '';
	margin-left: 8px;
	margin-right: 8px;
	font-size: 20px;
	display: inline-block;
	width: 3px;
	height: 3px;
	margin-bottom: 3px;
	border-radius: 10px;
	background-color: var(--bs-color);
}
footer .footer-info .link #menu-footer-menu li:last-child:after {content:''; margin-right:0px;margin-left:0; display:none;}
.page-content{font-size: 1rem;color: #ffffff;}
.page-content img{max-width: 100% !important;}
.page-content p{margin-bottom: 0}
.page-content a{color: #ffffff;text-decoration: underline;}

.pagination{
	--bs-pagination-bg: #222231;
	--bs-pagination-border-color: #222231;

	--bs-pagination-focus-bg: #222231;

	--bs-pagination-disabled-bg: #222231;
	--bs-pagination-disabled-border-color: #222231;
	--bs-pagination-hover-bg: linear-gradient(101deg, #F8A2ED 0%, #934EAE 100%);

	--bs-pagination-hover-border-color: #222231;
	--bs-pagination-active-border-color: #934EAE;
	--bs-pagination-active-color: #FFFFFF;
	--bs-pagination-active-bg: #934EAE;

}
.page-link.active, .active>.page-link {
	z-index: 3;
	color: var(--bs-pagination-active-color)!important;
	background-color: var(--bs-pagination-active-bg) !important;
	border-color: var(--bs-pagination-active-border-color)!important;;
}